<!DOCTYPE html>
<html lang="en">
	<head>
		<meta charset="UTF-8">
		<title>03_执行上下文栈</title>
	</head>
	<body>
		<!--
			1. 在全局代码执行前, JS引擎就会创建一个栈来存储管理所有的执行上下文对象
			2. 在全局执行上下文(window)确定后, 将其添加到栈中(压栈)
			3. 在函数执行上下文创建后, 将其添加到栈中(压栈)
			4. 在当前函数执行完后,将栈顶的对象移除(出栈)
			5. 当所有的代码执行完后, 栈中只剩下window
		-->
		<script type="text/javascript">
			var a = 10
			var bar = function(x) {
				var b = 5
				foo(x + b)
			}
			var foo = function(y) {
				var c = 5
				console.log(a + c + y)
			}
			bar(10)
			// bar(10)
		</script>

	</body>
</html>
